草庐IT

php - preg_replace 仅匹配的一部分

全部标签

ruby - Rspec 匹配哈希数组

我有一个哈希数组,为了便于论证,它看起来像这样:[{"foo"=>"1","bar"=>"1"},{"foo"=>"2","bar"=>"2"}]使用Rspec,我想测试"foo"=>"2"是否存在于数组中,但我不关心它是第一项还是第二项。我试过:[{"foo"=>"1","bar"=>"2"},{"foo"=>"2","bar"=>"2"}].shouldinclude("foo"=>"2"))但这行不通,因为哈希值应该完全匹配。有什么方法可以部分测试每个散列的内容吗? 最佳答案 怎么样?hashes=[{"foo"=>"1","

ruby - 如何使用正则表达式匹配字符或不匹配

我正在尝试获取一组可能有或没有分隔符的数字,并以标准格式返回它们。以SSN为例:ex1="Anexample123-45-6789"ex2="123.45.6789somemorethings"ex3="123456789thankyouRubymayIhaveanother"都应该进入返回“123-45-6789”的方法基本上,除数字或字母外的任何内容(包括任何内容)都应返回XXX-XX-XXXX格式的SSN。stumping的部分是正则表达式识别不能有任何东西的方式。到目前为止,我在识别我的ssn方面有什么:defformat_ssns(string)string.scan(/\d

ruby - 删除文件中第二个文件中没有匹配项的行的最快方法是什么?

我有两个文件,wordlist.txt和text.txt.第一个文件,wordlist.txt,包含中文、日文和韩文的大量单词列表,例如:你你们我第二个文件,text.txt,包含长段落,例如:你们要去哪里?卡拉OK好不好?我想创建一个新单词列表(wordsfount.txt),但它应该只包含来自wordlist.txt的行在text.txt中至少找到一次.上面的输出文件应该显示:你你们“我”未在此列表中找到,因为它从未在text.txt中找到.我想找到一种非常快速的方法来创建此列表,该列表仅包含第一个文件中在第二个文件中找到的行。我知道在BASH中检查worlist.txt中每一行的

ruby-on-rails - 如何从 Rails 控制台渲染部分内容?

我正在使用Rails4.0.3。如何从Rails控制台渲染部分内容? 最佳答案 试试这个(在控制台中):#initialsetupview_paths=Rails::Application::Configuration.new(Rails.root).paths["app/views"]av_helper=ActionView::Base.newview_paths#(Optional)includethisifyourpartialusesroutehelpers:includeRails.application.routes.u

ruby-on-rails - rails : Plus sign in GET-Request replaced by space

在Rails3(Ruby1.9.2)中我发送一个请求StartedGET"/controller/action?path=/41_+"但是参数列表是这样的:{"path"=>"/41_","controller"=>"controller","action"=>"action"}这里出了什么问题?-、*或.符号工作正常,只是+将被空格替换。 最佳答案 这是正常的URL编码,theplussignisashorthandforaspace:Withinthequerystring,theplussignisreservedasshor

ruby - gsub 部分替换

我只想替换这个表达式中括号中的组:my_string.gsub(/(.)*/,'replace_text')所以我得到:replace_text我知道我可以重复整个MARKER_START和MARKER_END替换表达式中的block,但我认为应该有更简单的方法来执行此操作。 最佳答案 您可以使用zerowidthlook-aheadandlook-behindassertions来完成.这个正则表达式应该在ruby​​1.9和perl以及许多其他地方工作:注意:ruby1.8仅支持先行断言。您需要前瞻性和后视性才能正确执行此操作。

ruby - 在 Ruby 中,有没有办法轻松地只删除数组中的 1 个匹配项?

在Ruby中,数组减法或拒绝>>[1,3,5,7,7]-[7]=>[1,3,5]>>[1,3,5,7,7].reject{|i|i==7}=>[1,3,5]将删除数组中的所有条目。是否可以轻松删除1次? 最佳答案 >>a=[1,3,5,7,7]>>a.slice!(a.index(7))=>7>>a=>[1,3,5,7] 关于ruby-在Ruby中,有没有办法轻松地只删除数组中的1个匹配项?,我们在StackOverflow上找到一个类似的问题: https:

ruby - 如何创建匹配所有请求并指向一个资源/页面的 Rails 3 路由?

我有一个需要暂时停止服务的Rails应用程序(Rails3.0)。虽然这是有效的,但我想创建一个新路由,将所有请求定向到单个静态内容。我设置了一个Controller来为我的静态页面提供服务。我试过这样的:match'*'=>'content#holding'和match'*/*'=>'content#holding'匹配通配符路由,如下所述:Rails3routeglobbing没有成功。这可能是一个非常简单的答案,但我想不通。/编辑/忘了说我在routes.rb文件的最顶部确实有这条规则。 最佳答案 Rails需要将url参数绑

ruby - 检查数组的元素是否部分存在于给定字符串中

我有一行文字thisistheline如果该数组中的元素之一,我想返回true:['hey','format','qouting','this']是上面给出的字符串的一部分。因此对于上面的行,它应该返回true。对于这一行hellomynameismartin它不应该。我知道include?但我不知道如何在这里使用它(如果它有帮助的话)。 最佳答案 >>s="thisistheline"=>"thisistheline">>['hey','format','qouting','this'].any?{|w|s=~/#{w}/}=>t

ruby - 如何在许多匹配项中使用 ruby​​ gsub Regexp?

我的csv文件内容在引用的文本中有双引号test,first,line,"youarea"kind"man",thanksagain,second,li,"my"boss"isyou",good我需要用“”替换每一个前面或后面没有逗号的双引号test,first,line,"youarea""kind""man",thanksagain,second,li,"my""boss""isyou",good所以"被替换为""我试过了x.gsub(/([^,])"([^,])/,"#{$1}\"\"#{$2}")但没用 最佳答案 您的正则表